# Open SI ASIC Chip Design

DESIGN DOCUMENT

Sdmay23-28

Client and Advisor: Dr. Henry Duwe

Tyler Green, Katherine Gisi, Aaron Sledge, William Zogg, Fulai Zhu

https://sdmay23-28.sd.ece.iastate.edu

sdmay23-28@iastate.edu

# 1 Team

#### 1.1 PROJECT MANAGEMENT STYLE ADOPTED BY THE TEAM

Our group completed our project using the agile project management style. One major component of our project was doing many iterations on several pieces of the project, with emphasis on both design and testing. Due to the needs of the Caravel project (overall size, ability to harden, etc.), going back and reworking components was a natural part of our process. We will also be sought input from our client over the course of the project because of our goal of developing a curriculum around chip design for new students in CprE. This management style worked relatively well for us.

#### 1.2 INITIAL PROJECT MANAGEMENT ROLES

- Katherine Gisi: Spokeswoman, SNN neuron design
- William Zogg: SNN neuron Design
- Tyler Green: SNN Design/Implementation, Software tool research, Environment setup
- Aaron Sledge: Software tool research & Documentation
- Fulai Zhu: Documentation

# 2 Introduction

# 2.1 PROBLEM STATEMENT

Iowa State University's ECpE department does not offer a full scope chip design curriculum that allows for students to design a chip, get it fabricated, and bring up their own design. This is an issue especially with the increasing demand for people in the workforce that can design complex chips. Our group is aiding in laying down the groundwork for getting a chip design curriculum, that encompasses the full scope of the process, started at ISU. We have undergone the design process and documented our experiences in Open-Source ASIC creation.

#### 2.2 INTENDED USERS AND USES

The general user groups of this project are threefold. The present users are those that will be continuing to build the infrastructure surrounding open-source ASIC bring-up at Iowa State University. These include our senior design team, future senior design teams, and our client who is a professor interested in building a cocurricular in line with this project. The future users will be those students of that potential cocurricular. Lastly, the broader users will be the open-source silicon community.

The present users who are partnering with our team to build infrastructure at ISU are described as outlined below.

- Key Characteristics: Interested in chip design, wants a working chip at the end of the day, looking to learn and share knowledge, have a desire to show their aptitude for chip design for future work-related opportunities.
- Needs: Documentation on processes involved, documentation on how to operate open-source design tools, solutions to potential problems, example projects to build that knowledge base.
- Benefits from this project: Knowledge gained from chip design process, knowledge of open-source design tools, ability to teach others, have a novel project to present to employers for future work-related opportunities.



The future users who may be involved in a class based on the work done by senior design projects such as this one can be characterized similarly.

- Key Characteristics: ECpE students, enrolled in a chip design course, want an end product/interested in something to hold in their hand. Additionally, future students of CprE 487/587 want the best class experience and labs possible.
- Needs: A relatively smooth class experience, examples to draw from, modularity of process flow. For 487/587 students, a working, reliable spiking neural network ASIC that can be used for a class lab.

• Benefits from this project: Completed design example, documentation for course work, knowledge given to the professor who may teach this course. For 487/587 students, a new piece of hardware to further the lab experiences possible for the course, have a novel project to present to employers for future work-related opportunities.



The open-source community is a user by nature of this project. Open-source silicon is a relatively new field, and the program that will be participated in for the fabrication of this chip was created to build the OS ecosystem in general. The attributes of the community as listed below.

- Key Characteristics: Participating in similar projects, may or may not have previous chip design experience, possibly looking to improve upon early iterations of a design
- Needs: New projects released and developed using fully open-source tools and information, well-documented instructions on how to use the product
- Benefits from this project: The open-source community will gain a new resource for a spiking neural network ASIC, as well as documentation and code for continuing/modifying an existing design



#### 2.3 REQUIREMENTS & CONSTRAINTS

#### **Physical Requirements**

• Our logic must fit within the space provided by efabless, specifically in a 10 square mm area (constraint)

#### **Environment Requirements**

- The project must be posted on a git-compatible repo and be publicly accessible and contain the following items:
  - The Caravel test harness with the SNN occupying the user space for the layout.
  - The GDSII in a compressed format
  - A makefile with targets to compress/uncompress, and clean the project
  - All source code required to generate the GDSII including any third-party components
  - The makefile should also include verify target to execute a test verification suite for the design
  - LICENSE files for the top-level project as well as each of the third-party components used
- Project is designed utilizing open-source tools (constraint)
- Project should pass checks provided in caravel harness GitHub repository before submitting to efabless (constraint)

# **Design and Functionality Requirements**

- Logic represents at least one neuron in a Spiking Neural Network
- The project must be targeted on the currently supported SkyWater Open PDK for the 130nm process
- Projects must use a common test harness and padframe based on the Caravel repo.
- Design uses a digital configuration
- Design has some reasonable amount of novelty
- Design must successfully pass the Open MPW precheck tool, including LVS and DRC clean using the referenced versions of OpenLane flow
- Design should implement and pass a simulation test bench for their design integrated into Caravel
- Functionality of fabricated design is software testable

# **Documentation Requirements**

- Repository should have a README file
- Create a bring up plan for future students to use to bring up our chip design in the caravel infrastructure.
- Create a tutorial document explaining all open-source tools necessary for the Efabless process.

# 2.4 Engineering Standards & Practices Used

**IEEE 1076.4-1995 - VITAL ASIC Modeling Specification**: Since our group is designing an ASIC according to a preset standard, we are therefore able to clearly communicate all aspects of our design to other engineers as necessary.

**IEEE 1500-2022 - Testability Method for Embedded Core-based Integrated Circuits**: Our group is creating an ASIC that will be tested, and those tests will follow a testing standard that will allow for others who come across our open-source design to easily understand what it is that we are doing. And validate the testing that we have done on our design.

**IEEE 1801-2018 - Design and Verification of Low-Power, Energy-Aware Electronic Systems**: This standard applies to our design because it will allow for others to analyze our chip timing and power consistently across a broad set of electric design automation.

# 3 Design

# 3.1 DESIGN CONTEXT

# 3.1.1 Broader Context

Spiking Neural Networks (SNN) is a third-generation network, it can be applied in many areas, such as image processing, voice recognition, and human-like computing (AI). Compared to other generation networks, SNN has advantages of higher energy efficiency, higher area efficiency, efficiency on chip learning and more fault tolerance. The disadvantages of SNN are training is difficult, the accuracy does not match the other generation networks, and programming frameworks are still in their infancy.

Our project is to make an open-source SNN in an application specific integrated circuit (ASIC), with the main point of our project being that we can provide others with our solution and document the process to help others complete their own ASIC. The communities that our design will be for will be for those looking to further the open-source design of digital chips. Specifically, those who are a part of the slack community looking to add to the amount of open-source chip designs that exist. This project will fulfill the needs of all who are looking to accelerate the growth and complexity of digital chip ideas and projects alike.

| Area | Description | Examples |
|------|-------------|----------|
|------|-------------|----------|

| Public health,<br>safety, and<br>welfare | How does your project affect the general well-<br>being of various stakeholder groups? These<br>groups may be direct users or may be<br>indirectly affected (e.g., solution is<br>implemented in their communities)                                                                                                                                  | Increasing/reducing exposure<br>to pollutants and other<br>harmful substances,<br>increasing/reducing safety<br>risks, increasing/reducing job<br>opportunities                                                                  |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          | Our project won't necessarily have a large<br>effect on the public's health. But it does<br>influence the public's welfare & quality of<br>life. Because as digital chip designs grow<br>more complex at a faster rate there will be<br>more complex and useful applications in the<br>electronics that are used by the public.                      | If our design is used for<br>purposes related to health<br>research/studies, the<br>results of those may have a<br>positive impact on public<br>health, which would be<br>indirectly caused by our<br>design.                    |
| Global,<br>cultural, and<br>social       | The open-source culture is one of openness,<br>growth, and collaboration. Our project is<br>part of an open-source initiative for silicon<br>design. It will accordingly reflect the values<br>of the community as we aim to create a<br>foundation for future groups whether in out<br>University or the open-source silicon<br>community at large. | This project as a spiking<br>neural network accelerator<br>can be used as a component<br>of an artificial intelligence<br>system. AI comes with its<br>own set of challenges and<br>potential violations of<br>community ethics. |
| Environment<br>al                        | What environmental impact might your<br>project have? This can include indirect effects,<br>such as deforestation or unsustainable<br>practices related to materials manufacture or<br>procurement.                                                                                                                                                  | Increasing/decreasing energy<br>usage from nonrenewable<br>sources,<br>increasing/decreasing<br>usage/production of non-<br>recyclable materials                                                                                 |
|                                          | The materials that are used to fabricate our<br>chip are natural resources. The mining of<br>those and the fabrication process itself is<br>often unsustainable and has an<br>environmental impact in the waste product<br>that is disposed of.                                                                                                      | Our project is to fabricate<br>the chip, so the usage of<br>nonrenewable sources and<br>non-recyclable materials<br>such as silicon, photoresist<br>or other chemical products                                                   |

|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                 | will increase.                                                                                                                                                                                   |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Economic | What economic impact might your project<br>have? This can include the financial viability of<br>your product within your team or company,<br>cost to consumers, or broader economic effects<br>on communities, markets, nations, and other<br>groups.                                                                                                                                                                                           | Product needs to remain<br>affordable for target users,<br>product creates or diminishes<br>opportunities for economic<br>advancement, high<br>development cost creates risk<br>for organization |
|          | In the long term, open-source chip design<br>has the potential to disrupt the industry and<br>pave the way for fast paced innovation and<br>economic growth in that area. Cost of<br>devices to consumers could be reduced. In<br>the short term, a curriculum at Iowa State<br>for chip design will create more learned<br>future engineers and give a broader base<br>for students to draw off and implement<br>their unique, creative ideas. | Our final product, a<br>fabricated SNN neuron chip<br>design, will be free and<br>publicly available for<br>other's use. It will need to<br>be documented well.                                  |

# 3.1.2 Prior Work/Solutions

#### **Current Literature**

One of the literature pieces that we are using as a basis for our project is called "An Adaptive Memory Management Strategy Towards Energy Efficient Machine Inference in Event-Driven Neuromorphic Accelerators". Now we are primarily using this literature piece to get a general idea of how SNN will likely need to be laid out as well as some of the high-level component ideas that will be needed for our SNN. The document can be found below:

An Adaptive Memory Management Strategy Towards Energy Efficient Machine Inference in Event-Driven Neuromorphic Accelerators: <u>https://par.nsf.gov/servlets/purl/10113424</u>

Advantages:

- Don't have to start designing SNN from scratch
- Gives an idea of some of the high-level components necessary to construct circuits
- Gives an idea of general functionality of the high-level components that it does describe

Disadvantages:

• The version of their SNN is more Bio based and therefore some of the components in there do not apply to our SNN

# **Relevant Projects**

This project was a continuation of an cocurricular development by the client. As such, a previous Iowa State senior design team performed a similar project and has provided resources to this team to continue developing a knowledge base. The work of the previous senior design team can be found as described in their website linked below.

Website: http://sddec22-17.sd.ece.iastate.edu/

This team will be following their personal advice, environment set-up documentation, and design flow. Our project will be different from theirs in functionality and structure. While their team completed the design of a bitcoin mining chip, our team will be creating a SNN accelerator.

#### **Related Models**

FPGA implementation is a close relative to ASIC design. To guide our design process on SNN acceleration, our team will be gleaning information from related FPGA projects. Our project is fundamentally different as the functionality is built into the circuit before the chip is created, but much of the circuit creation is similar. To get a grasp of the inputs, outputs, and steps required in an SNN, the paper "FPGA implementation of Spiking Neural Networks" was referenced.

Rosado-Muñoz, A., Bataller-Mompeán, M., & Guerrero-Martínez, J. (2016, April 21). FPGA implementation of spiking neural networks. IFAC Proceedings Volumes. Retrieved October 21, 2022, from

https://www.sciencedirect.com/science/article/pii/S1474667015404562? ref=pdf\_download&fr=RR-2&rr=75dc73ab0b3c8114

In breaking down the design of our neural network, logic structures were created. The work "Design of Various Logic Gates in Neural Networks" provided a starting place for our design.

Yellamraju, S. (2013, December 23). Design of Various Logic Gates in Neural nNetworks. ResearchGate. Retrieved October 21, 2022, from <u>https://www.researchgate.net/publication/259990623 Design of Various Logic Gates in</u> <u>Neural Networks</u>

#### 3.2 Design Exploration during 491

# 3.2.1 Design Decisions

The first decision we made is to make updates and iterations to user adder example and make changes to user adder example, by trying and adding components and change the functionality of components within the user adder example to gain more experience and familiarity with the design environment.

The second decision we made is to create an initial design sketch and design flow chart. This is important because we are laying the groundwork for creating high-level diagrams of circuits, identifying what components need to be present in each high-level section of the design, and creating K-Map for each component to identify gates that will be used.

The third decision we made is to add test block, the benefit of adding test block is it able to test our codes after finishing the test code and ensure it tests the desired criteria. If components don't behave as designed, then we will repeat the part-by-part block design then test the components again. The test block will save us a lot of time and improve fault tolerance.

# 3.2.2 Ideation

Each member individually investigated possible applications to use in our design. After brainstorming on our own, we compiled a list of possibilities that we could suggest to our client. The options we considered were

- 5. RSA encryption/decryption
- 6. Image reconstruction
- 7. Fingerprint reader accelerator
- 8. Digital encoder
- 9. Spiking neural network

To decide which application to use, we considered the requirements of our project, as well as where our own skills exist as a team. Our design requirements specify that the design must fit on the chip and should have some level of novelty. This eliminates fingerprint reading, RSA, image reconstruction, and digital encoder. With the remaining application of spiking neural network, we decided to select this since it would meet the requirements of the design and is something we believe we can implement.

# 3.2.3 Decision-Making and Trade-Off

Our group agreed to use spiking neural networks for the following reasons:

• It is a design which we will most likely be able to fit in our user area of the chip

- Our client has an interest in this area of technology
- It has a level of novelty that will help in our selection for the efabless program
- It has elements that would benefit from the acceleration of an application specific integrated circuit (ASIC)

After identifying these reasons, our group selected spiking neural networks as our application for design.

### 3.3 Proposed Design in 491

#### 3.3.1 Overview

The 3rd generation of neural networks, spiking neural networks, aims to bridge the gap between neuroscience and machine learning, using biologically realistic models of neurons to carry out computation.



# 3.3.2 Detailed Design and Visual(s)

SNN tries to more closely mimic a biological neural network. Therefore, instead of working with continuously changing in time values used in ANN, SNN operates with discrete events that occur at certain points of time. SNN receives a series of spikes as input and produces a series of spikes as the output (a series of spikes is usually referred to as spike trains). The general design descriptions:

1. At every moment of time each neuron has some value that is analogous to the electrical potential of biological neurons;

2. The value in a neuron can change based on the mathematical model of a neuron, for example, if a neuron receives a spike from the upstream neuron, the value might increase or decrease;

3. If the value in a neuron exceeds some threshold, the neuron will send a single impulse to each downstream neuron connected to the initial one;

4. After this, the value of the neuron will instantly drop below its average. Thus, the neuron will experience the analog of a biological neuron's refractory period. Over time the value of the neuron will smoothly return to its average.

To build SNN, first we need SNN neuron models. SNN neurons are built on the mathematical descriptions of biological neurons. There are a lot of models that can be used. For example, Hodgkin–Huxley model, or conductance-based model, is a mathematical model that describes how action potentials in neurons are initiated and propagated. It is a set of nonlinear differential equations that approximate the electrical characteristics of excitable cells such as neurons and muscle cells. It is a continuous-time dynamical system.



Also, SNN architectures is an important part of the design, there are three types of architectures, and we use Feedforward Neural Network which is a classical NN

architecture that is widely used across all industries. In such an architecture the data is transmitted strictly in one direction – from inputs to outputs, there are no cycles, and processing can take place over many hidden layers.



# 3.3.3 Functionality

Our design will provide customers with complete SNN design plans and drawings, as well as resources about programming. Users can get these resources for free when they need them and can use these resources to improve their own programs. For example, if a university needs to offer a course on SNN, then they can directly use our design to schedule the lab. Our design will provide each stage of SNN design including methods and processes. Our designs can save a lot of time and provide different ideas for those who need them.



#### **3.4 DESIGN ANALYSIS**

We are now starting to draw logical circuits and SNN hardware design, we think our design is feasible because the technology used in each step is essential, and as each step is completed, we can fabricate the SNN chip successfully. We are working on the hardware of the SNN as expected part of the construction, our plan is to complete the hardware design first and then solve the programming problem, this is the most reasonable plan for our overall design, because the hardware design is the cornerstone of the SNN chip design, and then all the processes must be worked on this basis.



This is our proposed design and flow at a high level. The data from the CPU will be gotten from the SRAM through an I/O. It will arrive first at a control block which will 'distribute' it accordingly. We need this block to interface with the built-in features of the Caravel harness that all the MPW design submissions sit on. Additionally it will allow the data to flow more efficiently. Then the neuron/MAC hardware accelerator will be fed the data and complete the calculations according to the model we choose and is in line with the MNIST data set. Last the output of the neuron will be restructured and stored according to a predefined function block.

# 4. Implementation

Since the end of 491 our design changes have been focused on refinements to the dataflow of the system and the creation of control logic for the system.

#### 4.1 DATA FLOW

Starting with dataflow, we've previously described the operation of each neuron, but we've made refinements to other building blocks that our neuron will need to communicate with. The below figure presents these changes. Our image was reduced to a 9x9 version with 8-bit values so that it could fit within our user area. To prepare the data for neuron processing, we've added other units including a randomizer module and a spike queue. The randomizer uses a pseudo-random algorithm in conjunction with the image values to generate the spikes for the current timestep. Non-zero timesteps and their corresponding identifier (neuron ID) are stored in the spike queue to be processed by the neuron.



# 4.2 CONTROL LOGIC

The main design additions made since the end of 491 is our control logic. Without the proper control, our hardware units will not be able to carry out their respective tasks. However, we must also be cautious of deadlocks that can cause our control logic to become "stuck".

The control logic is implemented using an 8-state FSM with the following states: LOAD, GENERATE SPIKES, LOAD SPIKE, LOAD WEIGHT, INTEGRATE, FIRE, LEAK VMEM, and TIME CHECK. Here is a brief description of state alongside the conditions that result in a state change:

- State
  - **LOAD**: The initial state of the entire system and default after a reset. This state loads each data structure needed for an inference including the image and weights. We move forward to GENERATE SPIKES upon receiving a start signal form the wishbone (CPU).
  - **GENERATE SPIKES:** Generate spikes using the randomizer unit and store them in the spike queue. Move to LOAD SPIKE when every input neuron (pixel) has moved through the randomizer.
  - **LOAD SPIKE:** Access the queue to load a spike and continue to LOAD WEIGHT when the queue signals valid output.
  - **LOAD WEIGHT:** Load the respective weight and the output neuron's current vmem which will be processed by the neuron asynchronously using the integrate mode of operation. When the weight is finished loading, we move to the INTEGRATE stage.
  - **INTEGRATE:** Take the output vmem from the neuron and store it. If we still have more spikes to process, then we move back to LOAD SPIKE. Otherwise, each spike has been utilized and we can move to the FIRE state.
  - **FIRE:** Process an output neuron for whether or not it has fired and move forward to LEAK VMEM. If the neuron spiked, we increment its respective register.
  - LEAK VMEM: If the neuron did not spike, we apply the leak operation to it.
     When all output neurons have been processed, move forward to TIME
     CHECK. Otherwise, we go back to FIRE and process the next neuron.
  - **TIME CHECK:** Here we check if we have processed all timesteps. If so, raise the done signal, reset the system, and go back to LOAD. Otherwise, we transition to GENERATE SPIKES to create spikes for the next timestep.



# 5. Testing

# 5.1 UNIT TESTING

The main unit that we tested for our design is the Verilog code for our neuron model. We tested it to make sure our design is working the way it is supposed to by constructing a test bench in Linux. It used a combination of C code to set up the virtual hardware that was provided to us as well as Verilog code to simulate the inputs and outputs to our neuron model.

The tools that we used were open-source Linux based software tools, it contained programs such as Icarus Verilog as well as docker set up in its environment. All of that along with a self-made test benches which, as mentioned before, were made with a combination of C based code files and Verilog based code files.

# **5.2 INTEGRATION TESTING**

The integration of our design was tested as follows. There were two major areas for integration testing along the way, integrating the block level components to the top-level design, and integrating the design into the harness.

Block to Top Testing:

To test each block we analyzed their outputs. We used GTKWave for viewing waveforms and Verilator for simulating system Verilog. For each level, block, mid, and top, we wrote

a number of test benches to verify that our block components were working as they should.

# Design to Harness Integration Testing

To test our design integration into the provided caravel harness we ended up using the test benches given to us. These test benches ensured that things such as logic analyzer connections, GPIO connections etc were all correct and working properly. Our design was able to pass each of those tests and operate correctly

#### **5.3 ACCEPTANCE TESTING**

The acceptability of our design if for the most part tested by the Efabless provided prechecks. These are the tests done before the submission is allowed onto the shuttle and to verify that all the components of the design are working in tandem. Our design was able to pass the necessary pre-check test verification that has to be passed before submission of the project. Now we are not able to submit our design to Efabless as of now since they have not opened up submission for a new shuttle just yet. But our desgin passing the given pre-check means that as soon as Efabless does open up submission for the next shuttle our design can be submitted to them right away.

### **5.6 INTERNAL TESTING**

In the case of the documentation that our client asked to create, for example the Caravel Tutorial Document in appendix 2, we were only able to test it by performing internal testing. For example: one of the members in our group had to go through the trouble of deleting WSL and everything on it and re-downloading all of the software tools and setting up the environment once more. He used the tutorial document since he did not remember how to do so and expressed his thoughts on the document so that the creator of those sections in the document could make improvements where the group thought improvements could be made.

# 5.7 HARDWARE AND SOFTWARE TESTING

Proper hardware testing is essential for ensuring the proper functioning and reliability of a board. The purpose of the hardware testing is to outline some steps that can be taken to test the connectivity, integrity, and functionality of the Caravel Nucleo board's components, as well as to ensure that the power rails have the correct voltage levels. By following these testing plans, any issues with the board can be identified and addressed promptly, leading to better performance and improved user experience.

The purpose of the software test is to provide instructions for running diagnostic software to characterize timing failure patterns between GPIO pads on Caravel for

related shuttles. This diagnostic software is essential to ensure that the Caravel part under the test is functioning correctly.

#### 5.8 SNN CHIP TESTING

this bring-up test plan outlines the crucial steps necessary to validate the functionality and performance of the NMNIST-based Spiking Neural Network (SNN) chip in the Efabless program. The plan includes test objectives to ensure functional correctness, performance, and interface compatibility, as well as a test setup that utilizes simulation tools, firmware, and test scripts. A variety of test cases are included, such as power-on self-test, input/output interface tests, basic functionality tests, integration tests, and performance tests. The plan also outlines the necessary test inputs and expected outputs, including classification results and debug and diagnostic information. The deliverables of the plan include a timeline for executing the test plan, test reports, and debug and optimization logs to document the results of each test case and any necessary troubleshooting steps taken during testing. Overall, this bring-up test plan is a critical step in ensuring the proper functioning and performance of the SNN chip.

#### 5.9 TESTING RESULTS

Our test results prove that our product is usable and does its job correctly. Every part of our design was tested and gave results to prove proper functionality along with meeting our requirements. Our design is from hardware to software, which is very useful and efficient because once we have completed the hardware design and testing, there will be a lot of room for trial and error in the code part.

# 6. Project Outcomes

In designing a digital neuron ASIC, there were a couple major outcomes which will be detailed in the following sections

# 6.1 SUBMISSION READY DESIGN

As mentioned in section 5.3 our design was tested and passed all prechecks. From this the design was deemed to be submission ready for the next open multi project wafer run.

Included are renderings of parts of the design.



Above: Top view of control logic. Below: Single Neuron Unit interacting with the I/Os



# 6.2 BRING-UP PLAN

A bring up plan was written for use when physical chip is delivered. At the time of writing this document, it is unsure when there will be another shuttle run. However, future team will have the ease of referencing this document to use our wafer to identify MNIST digits. See Appendix 1: User Manual for the full bring-up plan.

# 6.3 GITLAB REPOSITORY

The code for the project is contained within a public GitLab repository. The project serves the Open-Source community by taking its place in the ecosystem of designs to build from and inspire new ideas. The link to the repository is: https://git.ece.iastate.edu/sd/sdmay23-28

#### 6.4 DOCUMENTATION

Throughout the process of design, each step was documented in detail. It was tested according to section 5.6. The result is 38+ pages of documentation detailing:

- Environment Set-Up
- Getting Started
- Submission
- Daughter & Carrier Board
- Wishbone Bus
- Interrupts
- Logic Analyzer
- GPI
- ETC...

Additionally, various trouble-shooting sections are included based on this team's experiences. The documentation is included in Appendix 2.

# 7. Closing Material

# 7.1 DISCUSSION

The main result of our project is the final product we fabricated can satisfy all the requirements and work with general accuracy and efficiency.

Potential Applications for this project include:

- Basis for SNN accelerator unit
- Contribution to the Open-Source Silicon Community
- Inspire and empower students in the field of digital design
- Documentation for more teams and future classes

# 7.2 CONCLUSION

There is great potential for open-source ASICs in education and industry. This project provides a basis for future projects whether students at ISU or individuals in the Open-source SI ecosystem.

#### 7.3 References

1. Saha, Saunak, et al. "An Adaptive Memory Management Strategy towards Energy Efficient Machine Inference in Event-Driven Neuromorphic Accelerators." 2019 IEEE 30th International Conference on Application-Specific Systems, Architectures and Processors (ASAP), 2019, <u>https://doi.org/10.1109/asap.2019.000-2</u>.

- 2. "Digital Simulation of Spiking Neural Networks." *Pulsed Neural Networks*, 1998, https://doi.org/10.7551/mitpress/5704.003.0014.
- 3. "IEEE Standard VITAL Application-Specific Integrated Circuit (ASIC) Modeling Specification," in *IEEE Std 1076.4-1995*, vol., no., pp.1-96, 17 May 1996, doi: 10.1109/IEEESTD.1996.80811.
- 4. "IEEE Standard Testability Method for Embedded Core-based Integrated Circuits," in IEEE Std 1500-2022 (Revision of IEEE Std 1500-2005) , vol., no., pp.1-168, 12 Oct. 2022, doi: 10.1109/IEEESTD.2022.9916221.
- 5. "IEEE Standard for Design and Verification of Low-Power, Energy-Aware Electronic Systems," in IEEE Std 1801-2018 , vol., no., pp.1-548, 29 March 2019, doi: 10.1109/IEEESTD.2019.8686430.

6. Efabless. (n.d.). *Efabless/caravel\_board*. GitHub. Retrieved April 17, 2023, from <u>https://github.com/efabless/caravel\_board</u>

# Appendix

# 1. User Manual – Bring Up Plan

#### EE 492 Project Test Plan

#### **Purpose:**

The purpose of this document is to guide the students on how to test Efabless project from our team. This document provides firmware examples, flash programming and diagnostic tools for testing Open MPW and chipIgnite projects using Caravel. It also provides schematics, layout and gerber files for PCB evaluation and breakout boards.

#### **Components:**

NUCLEO-F746ZG or NUCLEO-F413ZH

Caravel Nucleo Hat

One or more Caravel breakout boards with a Caravel part installed

Two jumpers for J8 & J9

USB micro-B to USB-A cable



Figure 1: Efabless Caravel Board<sup>[1]</sup>

#### **Description:**

The bottom white board is Caravel Nucleo Board: F746ZG, which provide an affordable and flexible way for users to try out new concepts and build prototypes.

The black board on middle is a custom design from efabless, referred as the "Caravel Nucleo Hat", which provides a diagnostic software for characterizing timing failure patterns between GPIO pads on Caravel for the related shuttles.

The smaller yellow breakout on top (which should be white for most people) is referred as the "Caravel breakout". The fuction of this board is hold our SNN chip for testing.

#### **Prepare:**

The purpose of this step is to connect each components together amnd make the boards ready to test. There are some details need to notice during the assembling.

- 1. Install the jumpers on J8 and J9 in the 'HAT' position to enable the board to be powered by the Nucleo.
- 2. Plug the Caravel Nucleo Hat in Nucleo board pins
  - The USB on the hat should face the ST-LINK breakoff board on Nucleo and away from the push buttons on Nucleo
  - IMPORTANT: the FlexyPin socket allows you to swap breakout boards with different parts. You do not need to solder any pins.
  - Be careful not to bend a pin when inserting the breakout board. If one of the pins bends, use needle-nose pliers to re-straighten it.
  - When pressing the Caravel Hat board on the pin headers of the Nucleo, only press far enough to engage the pins. If you press to far, you can short the Flexy pins under the board against jumpers on the Nucleo.
- 3. Install a Caravel Breakout board into the socket on the Caravel Hat board
  - The Efabless logo should face the USB connector on the Hat
- Connect the USB cable from the connector CN1 on the Nucleo to your workstation / laptop.
- Connect a second USB cable from your desktop / workstation from connector CN13 on the opposite side of the Nucleo board from the ST-LINK breakaway board.
  - This port presents a mountable volume for the Flash filesystem on Nucleo and is how the software and firmware files are copied on to Nucleo. It is also used to retrieve the gpio\_config\_def.py file after the diagnostic completes.

#### Installation:

The purpose of this step is to complete the test background setting.

- Install the required tools including mpremote, mpy-cross and rshell. The diagnostic runs on a customized Micropython image on the Nucleo board. The Nucleo firmware image, diagnostic software and Makefile targets for installing and running the routines are located in the firmware\_vex/nucleo directory in the caravel\_board repo.
  - mpremote is used for connecting the Micropython
  - mpy-cross is a cross compiler for Micropython the compiles a python file into a binary format which can be run in micropython. It is used here to reduce the size of the files because the size of the flash on the Nucleo board is limited on some models.
- You will also need to install the stlink tools for your client. These are required to flash Micropython firmware on the Nucleo board.
- 3. After you made both USB connections, you will need to find the path for the Flash volume.
  - On MacOS, it should be located at //Volumes/PYBFLASH.
  - On Ubuntu, it should be mounted at /media/<userid>/PYBFLASH.
  - You will need to export FLASH=<path> or set the path in the Makefile at the top of the file.
- 4. It will be required to update the diagnostic software to get the latest enhancements and bug fixes. You can find the model of the Nucleo board on a label in the lower left corner of the Nucleo board opposite the ST-LINK breakaway board (F746ZG or F746ZH). Run one of the following make targets based on the model of your Nucleo board.

5. You can also just recompile and copy the files onto the flash by running on of the following make targets. After the flash completes, check the version of the software.

### **Test Process:**

#### I. Hardware Test:

Input: Check that all pins are connected correctly according to the board schematic. Test each pin individually for connectivity and short circuits

Expected Output: All pins should be connected correctly with no short circuits or open connections.



Figure 2: The Schematic of Caravel Nucleo Board<sup>[1]</sup>

Notice:

- The clock is driven by X1 with a frequency of 10MHz. To drive the clock with custom frequency, disable X1 through J6 and use the external pin for xclk
- The voltage regulator U5 and U6 supply 1.8V and 3.3V through J8 and J9. The traces have to be cut if they are supplied externally.
- vccd1 is connected to 1.8V through J3. The trace has to be cut if it is supplied externally
- vddio is connected to 3.3V through J5. The trace has to be cut if it is supplied externally
- To check if all pins are connected correctly, the following test plan can be developed:
  - 1. Check the schematic of the board to identify the expected connectivity of the pins.
  - 2. Using a multimeter, verify the connectivity of each pin against the expected schematic connectivity.
  - 3. Verify the connectivity of all power and ground pins.
  - 4. Check the resistance of the pins to identify any potential short circuits or open connections.
  - 5. Verify the signal integrity of the pins by sending test signals and measuring the output.
- To test that all parts of the component on the board are working well, the following test plan can be developed:
  - Check the datasheet of each component to identify the key parameters that need to be tested.
  - Develop test cases to verify the correct functioning of each component, based on their respective specifications.

- Use appropriate test equipment to measure and record the values of the parameters for each component.
- 4. Compare the measured values with the expected values from the datasheet to identify any discrepancies.
- 5. Define the acceptable tolerance range for each parameter and establish the pass/fail criteria accordingly.
- 6. Conduct additional tests, if necessary, to validate the correct functioning of each component.
- To test that all power rails have the correct voltage levels within the specified tolerance range, the following test plan can be developed:
  - 1. Identify all the power rails on the board.
  - 2. Using a multimeter, measure the voltage levels of each power rail.
  - Compare the measured voltage levels with the expected voltage levels as specified in the datasheet.
  - 4. Define the acceptable tolerance range for the voltage levels based on the specifications.
  - 5. Establish the pass/fail criteria based on the measured voltage levels and the acceptable tolerance range.
  - Conduct additional tests, if necessary, to verify the correct functioning of the power rails.

#### II. Software Test (The reseou

• To run the diagnostic, enter the following commands. The command depends on whether your project uses Caravel or Caravan (for analog). The PART variable is an ID for the part you are testing defined by you. It will be recorded in the output of the test for future reference.

| cd | caravel_board/firmware_vex/nucleo                                                                         |
|----|-----------------------------------------------------------------------------------------------------------|
|    | for digital (or analog) projects using Caravel & user_project_wrapper<br>e run PART= <part id=""></part>  |
|    | for analog projects using Caravan & user_analog_project_wrapper<br>e run_analog PART= <part id=""></part> |

Figure 3: Test Code for Caravel

The test will begin with the green LED on the Nucleo flashing 5 times. When the test

concludes, the green and red leds will be as follows:

| GREEN            | RED              | STATUS                                                      |
|------------------|------------------|-------------------------------------------------------------|
| 2 short + 4 long | off              | Full Success - BOTH IO<br>chains configured successfully    |
| 2 long           | 2 short          | Partial Success - LOW IO chains configured successfully     |
| 4 long           | 2 short          | Partial Success - HIGH IO<br>chains configured successfully |
| off              | 2 short + 4 long | Failed - BOTH IO chains<br>failed to configured fully       |
| off              | solid            | Test failed to complete                                     |

Table 1: Test Result Chart

Type Ctrl-C to exit the test diagnostic once it completes. If the test is completed for the part, run the **make get\_config** to retrieve the configuration file. The file will indicate the IO that was successfully configured. Successfully configured IO can be used for this part for firmware routines.

• The following will run a sanity check test using the gpio\_config\_def.py produced from the diagnostic above. The gpio\_config\_def.py file is stored from the make get\_config run above and local on your desktop.

To run the sanity check:

cd caravel\_board/firmware\_vex/nucleo
make sanity\_check FILE=gpio\_config\_def.py

#### Figure 4: Sanity Check Test

- Before using IO, you need to call configure\_io().
- You should leave the Caravel Nucleo board mounted and powered by Nucleo. The timing failure pattern specified in the gpio\_config\_def.py is sensitive to the capacitance loading on the pins that is present when the Caravel board is mounted on the Nucleo and may not be the same when the board is detached.
- You can flash and run your firmware with the Caravel Hat mounted on the Nucleo by running: make clean flash\_nucleo.
- GPIO TEST FILE

gpio\_config\_io.py:

https://github.com/efabless/caravel\_board/blob/main/firmware\_vex/gpio\_test/ gpio\_config\_io.py

#### gpio\_test.c:

https://github.com/efabless/caravel\_board/blob/main/firmware\_vex/gpio\_test/ gpio\_test.c

io\_config.c:

https://github.com/efabless/caravel\_board/blob/main/firmware\_vex/io\_config/ io\_config.c

#### III. SNN Chip Test

This is a bring-up test plan for our NMNIST-based Spiking Neural Network (SNN) chip in the Efabless program which is crucial to validate its functionality and performance.

#### 1. Test objectives:

- Functional correctness: Ensure that the SNN chip correctly implements the NMNISTbased neural network and can process input data as intended.
- Performance: Validate that the chip meets the target performance metrics (e.g., classification accuracy, latency, power consumption) for the NMNIST dataset.
- Interface compatibility: Confirm that the chip interfaces correctly with external components, such as memory and peripherals.
- 2. Test setup:
- Simulation tools:

- o Icarus Verilog: Used to simulate RTL (Register Transfer Level) designs
- GTK wave: Used to view the waveform output generated by simulation
- Firmware:
  - Caravel harness repo: Provides makefiles that handle the compilation of CPU software to be run on a simulated CPU along with the rest of the user project wrapper.
- Test scripts:
  - Python: A popular scripting language used for automation and testing.
  - JMeter: An open-source load testing tool used for testing the performance and scalability of web applications.
  - Postman: A tool used for testing and debugging APIs.
- 3. Test cases:
- Power-on self-test (POST): Verify that the chip initializes correctly upon power-up and performs any necessary self-tests.
- Input/output (I/O) interface tests: Validate the proper functioning of all I/O interfaces, including communication protocols and data transfers with external components.
- Basic functionality tests: Test individual components and sub-blocks of the SNN chip to ensure that they perform as intended (e.g., neuron models, synapses, learning rules).
- Integration tests: Confirm that the SNN chip components work together correctly as a complete system when processing NMNIST data.
- Performance tests: Evaluate the chip's performance against predefined performance metrics (e.g., classification accuracy, latency, power consumption).

#### 4. Test inputs:

 Preprocessed NMNIST dataset: Use the NMNIST dataset after applying the necessary preprocessing steps, such as converting images to spike trains or other suitable formats for SNN processing.

#### 5. Expected outputs:

- Classification results: The chip should produce correct classification outputs for the input NMNIST dataset with an accuracy comparable to that of the target performance metrics.
- Debug and diagnostic information: Collect relevant debug and diagnostic data during testing to aid in troubleshooting and optimizing the chip's performance.

#### 6. Test deliverables:

- Develop a timeline for executing the test plan, including milestones for completing individual test cases and achieving overall objectives
- Test reports: Document the results of each test case, including pass/fail criteria, observed outputs, and any issues encountered.
- Debug and optimization logs: Record any necessary debugging and optimization steps taken during testing, along with their outcomes.

#### Simulation code:

```
/*
```

\* SPDX-FileCopyrightText: 2020 Efabless Corporation

```
*
```

\* Licensed under the Apache License, Version 2.0 (the "License");

\* you may not use this file except in compliance with the License.

\* You may obtain a copy of the License at

\*

\* http://www.apache.org/licenses/LICENSE-2.0

\*

\* Unless required by applicable law or agreed to in writing, software

\* distributed under the License is distributed on an "AS IS" BASIS,

\* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

\* See the License for the specific language governing permissions and

\* limitations under the License.

\* SPDX-License-Identifier: Apache-2.0

```
*/
```

// This include is relative to \$CARAVEL\_PATH (see Makefile)
#include <defs.h>

#### #include <stub.c>

// -----

#### /\*

MPRJ Logic Analyzer Test:

- Observes counter value through LA probes [31:0]
- Sets counter initial value through LA probes [63:32]
- Flags when counter value exceeds 500 through the management SoC gpio
- Outputs message to the UART when the test concludes successfuly

#### \*/

void main()

#### {

int j;

/\* Set up the housekeeping SPI to be connected internally so \*/
/\* that external pin changes don't affect it. \*/

// reg\_spi\_enable = 1;

// reg\_spimaster\_cs = 0x00000;

// reg\_spimaster\_control = 0x0801;

// Connect the housekeeping SPI to the SPI master

// so that the CSB line is not left floating. This allows

// all of the GPIO pins to be used for user functions.

- // The upper GPIO pins are configured to be output
- // and accessble to the management SoC.
- // Used to flad the start/end of a test
- // The lower GPIO pins are configured to be output
- // and accessible to the user project. They show
- // the project count value, although this test is
- // designed to read the project count through the
- // logic analyzer probes.
- // I/O 6 is configured for the UART Tx line

reg mprj io 31 = GPIO MODE MGMT STD OUTPUT; reg\_mprj\_io\_30 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_29 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_28 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_27 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_26 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_25 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_24 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_23 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_22 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_21 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_20 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_19 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_18 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_17 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_16 = GPIO\_MODE\_MGMT\_STD\_OUTPUT; reg\_mprj\_io\_15 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_14 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_13 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_11 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_10 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_9 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_8 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_7 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_5 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_5 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_2 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_2 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_3 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_2 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_2 = GPIO\_MODE\_USER\_STD\_OUTPUT; reg\_mprj\_io\_1 = GPIO\_MODE\_USER\_STD\_OUTPUT;

#### reg\_mprj\_io\_6 = GPIO\_MODE\_MGMT\_STD\_OUTPUT;

// Set UART clock to 64 kbaud (enable before I/O configuration)
// reg\_uart\_clkdiv = 625;
reg\_uart\_enable = 1;

// Now, apply the configuration
reg\_mprj\_xfer = 1;
while (reg\_mprj\_xfer == 1);

// Configure LA probes [31:0], [127:64] as inputs to the cpu
// Configure LA probes [63:32] as outputs from the cpu
reg\_la0\_oenb = reg\_la0\_iena = 0x00000000; // [31:0]

```
reg_la1_oenb = reg_la1_iena = 0xFFFFFFF; // [63:32]
reg_la2_oenb = reg_la2_iena = 0x00000000; // [95:64]
reg_la3_oenb = reg_la3_iena = 0x00000000; // [127:96]
```

```
// Flag start of the test
reg_mprj_datal = 0xAB400000;
```

// Set Counter value to zero through LA probes [63:32]
reg\_la1\_data = 0x00000000;

// Configure LA probes from [63:32] as inputs to disable counter write
reg\_la1\_oenb = reg\_la1\_iena = 0x00000000;

```
while (1) {
    if (reg_la0_data_in > 0x1F4) {
        reg_mprj_datal = 0xAB410000;
        break;
    }
}
print("\n");
print("\n");
print("Monitor: Test 1 Passed\n\n"); // Makes simulation very long!
reg_mprj_datal = 0xAB510000;
```

#### IV. Reference

}

[1] Efabless. (n.d.). *Efabless/caravel\_board*. GitHub. Retrieved April 17, 2023, from <a href="https://github.com/efabless/caravel\_board">https://github.com/efabless/caravel\_board</a>

# 2. Caravel Tutorial Document

## 1. Overview of the Efabless Process Steps

The Caravel project is a long project that will take time and dedication to complete. In this section an overview of the step-by-step process for the caravel project will be explained from start to finish.

- 1) The very first thing that will need to be done is to familiarize yourself with the Caravel harness.
  - a) You will want to study all of the components that make up the Caravel harness and their functionalities. This can be done by reading through the following website that contains information about the user harness.
  - b) Link: <u>Efabless Caravel "harness" SoC Caravel Harness documentation</u> (caravel-harness.readthedocs.io)
- 2) You will have to download all necessary efabless tools and familiarize yourself with how they work.
  - a) how to do so is explained in the sections below.
- 3) You will need an open-source Git repository.
  - a) This is to store the caravel project as well as give detailed documentation on what your project does and how it works in the form of a README.
  - b) If you are part of a senior design team the ETG will set up your repository for you, but it will be up to you to update your repository as necessary.
- 4) Next you will need to come up with a chip design idea that you believe will be able to fit within the user area of the Caravel harness slowly making a high level RTL design of your project Idea to implement into the user area.

- 5) After coming up with an idea and creating a viable RTL for it you will need to slowly add all of the components/modules that comprise your design idea into the user area
  - a) Be sure to set up test benches testing each module individually to check for functionality before implementing them into the caravel harness.
  - b) Then slowly integrate each module into the caravel harness setting up test benches to check for functionality between each of the modules you have as you implement them all into the user area.
- 6) After successfully integrating your design into the user area next you will need to harden your design inside of your lynux environment.
  - a) Explanation on how to do so is in section 4.3.
- 7) Once you have successfully hardened your design you will need to instantiate it in the project wrapper.
- 8) After you have instantiated your design inside of the wrapper you will harden the project wrapper.
  - a) Explanation on how to do so is in section 4.4.
- 9) After hardening and creating the new project wrapper you will test its functionality using the test benches given in the caravel repository as well as any personal test benches you design for your project to ensure that it is working properly.
  - a) Explanation on how to do so is in section 4.5.
- 10) Once your project has passed all test benches the last thing to do is to run the final checks on it. Your project must pass these prechecks before you attempt to submit your design to Efabless
  - a) Explanation on how to do so is in section 4.6.
- 11) After your project has passed the final prechecks you will submit your project to efabless. Keep in mind that it may take several hours for your design to be fully

submitted to efabless due to the final tests that will need to be performed on your project submission on efabless submission page.

- a) Explanation on how to submit your project and what needs to be done is in section 8.
- 12) The next thing that needs to be done is to prepare a bring-up plan for your project. You will need to come up with steps to test the physical PCB board & all componnents on it, as well as testing your overall project's functionality. Essentially coming up with tests that have hardware and software aspects to it to ensure that everything is functioning properly.
  - a) To understand what to expect to be on the PCB boards that you will receive you may review all of section 9 of this document.
- 13) Eventually you will get your project design back in the form of a die soldered to a PCB board. You will obtain a carrier board as well as a daughter board. The only thing left to do is to execute your bring-up plan to see how well your project turned out.

## 2. Windows Subsystem for Linux Installation (WSL2) on Windows 11

Source: Install WSL | Microsoft Learn

#### 2.1 OPENING POWER SHELL

First open PowerShell on your windows computer, you can do so by clicking in the search bar at the bottom of your windows interface circled in green as seen in figure 1.



*Figure 1. Windows search bar* 

A search window, as displayed in figure 2 should appear.



Figure 2. Windows search window

Afterwards type in PowerShell into your search window and open it as seen in figure 3.



Figure 3. PowerShell App

#### 2.2 INSTALLING WSL2

Once PowerShell is up and running type in the following command into the command line and run it refer to figure 4.

Command: wsl --install

This will enable all the necessary features in order to run Linux on your machine. It will also install the Ubuntu distribution of Linux on your machine. You will be prompted to create a username and password for Ubuntu, it is very important that you remember your password as you will need it every time you open Ubuntu and attempt to run the first command.



Figure 4. Installation of wsl through PowerShell

# 3. Setting Up Dependencies for the Caravel Repository

#### 3.1 UPDATING UBUNTU TO LATEST VERSION

The first thing that will need to be done is to make sure that your system is running on the latest version of Ubuntu. To do so you will have to open up Ubuntu by typing it in the same search bar the same way that you opened PowerShell. After doing so type the following command into the command line and run it. Before Ubuntu executes the command, you may be prompted to type in your password that you created in the previous step. Refer to figure 5.

Command: sudo apt update



Figure 5. Ubuntu

As can be seen in figure 5 you will be prompted to type in your password before Ubuntu executes the above-mentioned command. It is important to note that as you type in your password Ubuntu will not display any of the characters that you type in, this is for security reasons. Understand that Ubuntu is receiving the characters that you are typing there is nothing wrong with your terminal.

After typing in the correct password Ubuntu will execute the command that you entered prior to it prompting you with a request for your password as can be seen in figure 6.





After Ubuntu has executed the "sudo apt update" command in the second to last line in figure 6 it will tell you the number of packages you are able to upgrade as well as how to view the list of upgradable packages if needed. Type the following command into the command line and run it. This command will upgrade all of the packages listed from the prior command. You will be promoted with a question asking if you wish to continue where you can enter "Y" for yes and "n" for no, refer to figure 7.

Command: sudo apt upgrade



Figure 7. Ubuntu executing sudo apt upgrade

Enter in 'Y' and Ubuntu will upgrade your packages. Depending on the number of packages that need to be upgraded it could take Ubuntu anywhere from a few seconds to a few minutes to finish upgrading the packages. Once Ubuntu has finished it will display "done" in the second to last line, indicating that the upgrading process was completed and successful.

#### 3.2 INSTALLING DOCKER IN UBUNTU

Source: Install Docker Engine on Ubuntu | Docker Documentation
Docker for WSL

First you must be in your home directory, to do so enter the following command into the command line and run it. This will return you to your home directory.

Command: cd

Afterwards you will have to update the apt package index, enter in the following command in the command line and run it. The output should look like figure 8 below.

Command: sudo apt-get update



Figure 8. Output of sudo apt-get update command

If Ubuntu is unable to run the previous command then your default unmask could be incorrectly configured. If that is the case, then type in the following commands in the command line and run each one separately.

Command: sudo chmod a+r /etc/spt/keyrings/docker .gpg

Command: sudo apt-get update

Next you will have to install the Docker Engine, container, and Docker Compose. Type in the following command in the command line and run it. The following command will install the latest version of docker on your machine.

Command: sudo apt-get install docker-ce docker-ce-cli containerd.io dockercompose-plugin

To verify that docker installed correctly type in the following command line and run it. The output should look like figure 8 down below, if it does then you have successfully downloaded docker into your Linux environment.

Command: sudo docker run hello-world





#### **3.3 TROUBLESHOOTING**

Based on past experience, WSL may or may not work easily with docker. The recommended way to use WSL and docker is to install Docker Desktop for Windows, then enable a setting to connect to WSL; however, there have also been issues where Docker Desktop does not start correctly on Windows either. To avoid using Docker Desktop, you can try following the normal install steps for a traditional Ubuntu installation. This has its own issues, specifically with GPG key errors and the daemon not starting correctly by default.

GPG key error:

`sudo apt-get update` may fail with an error about gpg keys. To fix this, you can run the following from the directory "/etc/apt/keyrings":

curl -fsSL <u>https://download.docker.com/linux/ubuntu/gpg</u> | sudo gpg --dearmor o /etc/apt/keyrings/docker.gpg

Then try `sudo apt-get update` again

Docker daemon not running:

The docker daemon may not start after installing docker, so `sudo docker run helloworld` give an issue with not being able to communicate with the docker daemon. To solve this, try running `sudo dockerd &`. This runs the command in the background, but the output will still be sent to the terminal. You should still be able to run `sudo docker run hello-world`. If that does not work, then enter in the command below:

Command: sudo service docker start

Your daemon error should be fixed by now.

#### **3.4 INSTALLING PYTHON 3 WITH PIP**

Source: <u>How to Install Python Pip on Ubuntu 20.04 | Linuxize</u>

Installing Python 3 with Pip is the final dependency needed in order to use the caravel (repository). Type the following command into the command line. This will install the latest version of Python 3 along with PIP at the same time.

Command: Sudo apt install python3-pip

After running the previous command type the following command in the command line to verify that the installation executed correctly.

Command: pip3 --version

The output should look like figure 9 down below, the versions number may vary.



Figure 10. Pip and Python version check output

#### 3.5 INSTALLING KLAYOUT (OPTIONAL)

All though this software tool is not required in order to be able to use the caravel environment it is a nice visual aid that will help with understanding how much space your design occupies in the user project area. Type and run the following commands:

- 1. sudo apt update
- 2. sudo apt upgrade
- 3. sudo apt –y install klayout

It should only take your terminal a few minutes at most to download the klayout software tool. Again it is not necessary but can prove to be extremely useful when it comes to understanding how much of the user area space is taken up by your design.

### 4. Getting Started with the Caravel Repo

Source: <u>caravel\_user\_project/quickstart.rst at main · efabless/caravel\_user\_project ·</u> <u>GitHub</u>

Before you are able to do anything with the Caravel repository you must first set up the local environment inside of Linux inside of your project repository.

#### 4.1 CLONING YOUR PROJECT REPOSITORY INTO LINUX

First you must clone your project repository given to you by the ETG into Linux. Type the following command into your command line and run it.

Command: git clone <your repo URL>

Upon running that command, you may be prompted to give your username and password in order to clone your repo. The username should be your school email and the password should be your school password. After entering that Linux should clone your repository without issue.

#### 4.2 SETTING UP LOCAL CARAVEL ENVIRONMENT

The first thing that you will need to do inside of Linux is to enter into your project repository. Type the following command into your command line and run it to enter your project repository.

Command: cd ~/<your project name>

Next you will need to run the following commands one at a time.

#### Commands:

- 1. mkdir dependencies (you only need to do this once)
- 2. export OPENLANE\_ROOT=\$(pwd)/dependencies/openlane\_src
- 3. export PDK\_ROOT=\$(pwd)/dependencies/pdks
- 4. Make setup

If you are running into an error with the communication with daemon from docker please refer to the trouble shooting section under installing docker in Ubuntu.

Commands 2 & 3 will have to be exported every time that you start a new shell (every time you reopen your terminal). After the fourth command is executed, the following tools will be installed:

- Caravel\_lite
- Management core for simulation
- Openlane to harden your design
- Pdk

These installations should only take a few minutes to complete.

#### 4.3 BEFORE HARDENING USER PROJECT

Source: MPW-6 Walkthrough - YouTube (17:20 & 21:36)

Before you go to harden your project there are a few files that have to be modified so that the make command knows what to harden. The first file that has to be changed is in the user project example directory and is called the config.tcl file. You may find and change the config file under

caravel\_user\_project/openlane/user\_proj\_example/config.tcl or you may make your own directory inside of openlane and create your own config file. Below I will show you how to modify the config file that is already present in the directory that I described above.

1. In the config.tcl file you will change the "DESIGN\_NAME" section to the name of your project, so change line 21 by replacing user\_proj\_example with your project name.

2. Next you will have to change line 25, changing the user\_proj\_example.v file to your projects .v file or files depending on how many different Verilog scripts your project has.

3. If you have an issue with hardening your project you may have to play around with lines 34 and 39. For line 34 only change the right two numbers for the die area. So only change the 900 and or the 600. And for line 39 you must choose a number that is no greater then 1. But to keep the number as low as possible is desirable as you may receive a number of errors or violations for trying to make the placement target density too high.



Figure 11. config.tcl file for user project example

#### 4.4 HARDENING USER PROJECT TO TEST OPEN LANE SETUP: EXAMPLE - USER\_ADDER

Testing your openlane set up is essential due to the fact that you must be able to harden your design before you are able to do anything else regarding too project submission to Efabless. Type and run the following command:

Command: make user\_adder

Your terminal will then run through 48 steps, by the end of the process the output of your terminal should look the same as figure 12 below.



#### Figure 12. Output of hardening of user adder successfully

As can be seen in figure 12 there are two warnings given, however you can ignore these warnings for now because they will not hinder you any time soon.

#### 4.5 BEFORE HARDENING THE USER PROJECT WRAPPER

Before you go on to harden your project inside of the project wrapper you once again have to change the contents of the corresponding config file or create your own. For this example, I will describe how to change the config file that is already present in the caravel user project. The location of the config.tcl file is in caravel\_user\_project/openlane/user\_proj\_wrapper/config.tcl.

1. You will have to edit line 42 changing the mprj clock to whatever the name is of the clock that you made for your project.

2. Change lines 57,60, & 63 to your projects corresponding file types.



Figure 13. Config file fore user project wrapper

#### 4.6 CREATING USER PROJECT WRAPPER

Before you are able to run the final checks you must first take your harden design and place it inside of the caravel project wrapper. After doing so type and run the following command to create the user project wrapper inside of your environment.

Command: make user\_project\_wrapper





#### 4.7 RUNNING TEST BENCH SIMULATIONS ON YOUR DESIGN

After hardening your design inside of the user project wrapper there are only a few more things that will need to be done before your design is ready for submission to Efabless. First you will be instructed on how to run personal test benches for the user adder project so that you can familiarize yourself with how the output of the tests should look like inside of the terminal. However, the example will only use personal test benches because the user adder project will fail all other test benches that your project must pass before submission to Efabless. The other test benches that your project will need to pass are for the io ports, mprj, the logic analyzer, and wishbone bus which will be addressed after the example with the user adder project. Your project will need to be tested at both rtl and gl and passed at both levels before your design is ready for submission.

#### 4.8 Example

There are two personal test benches to run on the user adder, the commands for each of those tests are as follows:

Command: make verify-user\_adder\_test1-<rtl or gl>

The output for the previous command should look similar to figure 15 down below



Figure 15. Output of make verify-user\_adder\_test1

Command: make verify-user\_adder2-<rtl or gl>

The output for the previous command should look similar to figure 16 down below



Figure 16. Output of make verify-user\_adder\_test2

There are a number of other tests that your design will have to pass before submission. However, you will not be able to use the user adder project to run the tests down below. The tests will time out if you try to run them using the user adder project and fail the test.

To run each test individually you will have to enter in one of the following commands:

Command: make verify-io\_ports-<rtl or gl>

Command: make verify-mprj\_stimulus-<rtl or gl>

Command: make verify-la\_test1-<rtl or gl>

Command: make verify-la\_test2-<rtl or gl>

Command: make verify-wb\_port -<rtl or gl>

4.9 RUNNING FINAL CHECKS ON YOUR PROJECT BEFORE SUBMISSION

The final thing that you will have to do is to pass all of the prechecks set out by Caravel. There are 13 in total that your design will have to pass before your project is ready for submission to caravel:

1. License check: caravel will check your directory and make sure that there are no prohibited license files within it.

2. Make file: caravel will check your make file in your directory and ensure that it is valid.

3. Default: caravel will check to see if you have edited the 'README.md' file to<br/>ensure that you do not maintainthe default'README.md' file that comes with the caravel repository.

4. Documentation: caravel will check to see if there is appropriate documentation in your directory.

5. Consistency: Caravel will check the following.

A) Hierarchy - Module user\_project\_wrapper is instantiated in caravel.

B) Complexity - Netlist caravel contains at least 8 instances.

C) Modeling - Netlist caravel is structural.

D) Submodule Hooks - All module ports for user\_project\_wrapper are correctly connected in the top- level netlist caravel.

E) Power Connections - All instances in caravel are connected to power.

F) Ports - Netlist user\_project\_wrapper ports match the golden wrapper ports.

G) Complexity - Netlist user\_project\_wrapper contains at least 1 instance.

H) Modeling - Netlist user\_project\_wrapper is structural.

I) Layout - The GDS layout for user\_project\_wrapper matches the provided structural netlist.

J) Power Connections - All instances in user\_project\_wrapper are connected to power.

K) Port Types - Netlist user\_project\_wrapper port types match the golden wrapper port types.

6. XOR: Checks for total XOR differences if looking for more information on this test check the file in the directory that the pre-check suggests.

7. Magic DRC: Checks for any violations in the design rule check

8. Klayout FEOL: Checks for DRC violations

9. Klayout BEOL: Checks for DRC violations

- 10. Klayout Offgrid: Checks for DRC violations
- 11. Klayout Metal Minimum Clear Area Density: Checks for DRC violations
- 12. Klayout Pin Label Purposes Overlapping Drawing: Checks for DRC violations
- 13. Klayout ZeroArea: Checks for DRC violations

Each one of these checks will have to be passed before you are able to submit your project to Efabless. In order to execute these tests, enter the following commands into your terminal:

Commands: make precheck (you only need to do this once)

Commands: make run-precheck

If your project passes all of the prechecks the output in your terminal should appear similar to figure 17 below.



Figure 17. Output of make run-percheck

After this step is complete you must make sure that your repository is up to date and that you push all necessary files or edits to previous file to your repo. You now should have a solid base of understanding of the caravel repository, how to opperate it, as well as what will need to be done for your project.

# 5. Getting started with the Wishbone Bus

#### **5.1 WHAT IS THE WISHBONE BUS**

The wishbone bus is a 32-bit bus connecting the user project wrapper with the management SoC. It includes the following user project wrapper ports:

| Port Description       | Port name |
|------------------------|-----------|
| Clock                  | wb_clk_i  |
| Reset                  | wb_rst_i  |
| Strobe                 | wbs_stb_i |
| Cycle                  | wbs_cyc_i |
| Write enable           | wbs_we_i  |
| Select                 | wbs_sel_i |
| Data in (to user area) | wbs_dat_i |
| Data out (to SoC)      | wbs_dat_o |
| Address                | wb_adr_i  |
| Acknowledgement        | wbs_ack_o |

#### Note: Addresses must be in 4-byte increments

#### 5.2 Using the wishbone bus from the Management SoC

In a caravel testbench, the management SoC can communicate using the wishbone using the following steps:

- 1. Enable wishbone: reg\_wb\_enable = 1;
- 2. Write to bus: <32-bit address> = <32-bit data>; (the user area may respond to

any address from 0x3000 0000 to 0x7FFF FFFF)

3. Read from bus: uint32 t in data = <32-bit address>;

#### 5.3 WRITING TO THE USER AREA

The user area can respond to a write request using the following process:



where 'valid = wbs\_cyc\_i && wbs\_stb\_i'.

You should check if the address on the wishbone matches your component's address before reading/writing/acknowledging the data.

#### 5.4 READING FROM THE USER AREA

The user area can respond to a read request using the following process:



The caravel harness github repository includes the user\_proj\_example, which has some interaction with the wishbone, as well as some tests in the design verification (DV) verilog directory.

Video: Caravel Wishbone bus demo - YouTube



Necessary Repositories:

- 1. <u>GitHub mattvenn/wishbone\_buttons\_leds at caravel</u>
- 2. <u>caravel\_user\_project/README.md at wishbone-demo</u> · <u>mattvenn/caravel\_user\_project · GitHub</u>

# 6. Getting started with the Logic Analyzer

#### 6.1 WHAT IS THE LOGIC ANALYZER

The logic analyzer is a 128-bit port going to/from the user area and management SoC. It allows the SoC to "probe" any desired signals from the user area after fabrication (but they cannot be changed once fabricated, so choose wisely). This is useful for debugging signals during the bring-up process, possibly to discover bugs in the hardware, or to verify that they are working correctly.

#### 6.2 How to use the logic analyzer in the user area

The logic analyzer can be used by connecting the 128 bits to any of the desired signals in your design. This can be seen in the user\_proj\_example caravel module.



Here, the logic analyzer is used to set the counter value. It takes the or-reduction of la\_write (or'ing all bits together, |x operator) and if it is 1, sets the count to the la\_write and'ed with la\_input.

#### 6.3 How to use the logic analyzer from the management SoC

For details on how to use the logic analyzer from the SoC, refer to the la\_test1 dv directory in the base caravel repository.



First, the logic analyzer probes are configured to be inputs or outputs, then the data is written (or read) from the data register.

### 7. How to use interrupts

#### 7.1 WHAT IS AN INTERRUPT

An interrupt is a signal from the hardware that pauses the current processor execution and begins execution somewhere else. This is commonly used to avoid blocking code, where the CPU continuously polls the hardware for data. Instead, the hardware can alert the CPU when a condition is met, such as a timer reaching a specified value.

#### 7.2 HOW TO TRIGGER AN INTERRUPT FROM THE USER AREA

An interrupt can be triggered from the 3 irq bits available to the user area. Each of these bits corresponds to an interrupt. The interrupt should be high for one clock cycle, and low otherwise.

#### 7.3 HOW TO RECEIVE AN INTERRUPT IN THE SOC

Interrupts can be enabled in the SoC in the following way:



The irq\_vex.h header adds the functions/macros for irq\_setmask, irq\_setie, etc. The code starts by setting the mask to 0 and enabling interrupt 1. The external flag variable is the variable used by the interrupt handler. This handler is part of the existing simulation infrastructure, so it is not necessary to write it. The interrupt handler must be placed at a specific location in the SoC's program memory, so it is simpler to use the example provided by the harness repository by default. The second irq\_setmask() sets the correct bit for the irq we are triggering in hardware. In this case, it is the 0th interrupt (irq bit 0 in the user area). Next, the req\_user\_irq\_enable register should have the corresponding bit set for the interrupt you are using. Finally, the req\_userX\_irq\_en must be set to 1 (where X is the irq index). In simulation, the flag variable will be set to 1 when the interrupt is triggered.

## 8. How to use klayout to view GDS files

Klayout can be a very useful tool when it comes to seeing the cells that you have added to the user project wrapper. So, in this section of the tutorial document, you will be instructed on how to view the project wrappers as well as how to interpret the cells. Klayout is only useful after you have hardened your design inside of the user\_project\_wrapper. The first thing you need to do is to enter the directory of your project where you hardened your design. Then type in the following command:

Command: find -name '\*klayout.gds'

This command will find all of the files within the directory you are in that contain the "klayout.gds" attachment. The output will look similar but not the same as figure 18 down below.



Figure 18. Finding all klayout gds files

As can be seen from figure '#' above you are able to look at just the user area or the user project wrapper as a whole. The file names starting with **./user\_project\_wrapper** are the GDS files that contain your project in the user area inside of the user project wrapper. The file names that start with **./user\_adder** are the GDS files that will show the user area with the user adder inside of it. For either one of the two the way to tell which file is the most recent is by looking at the numbers in the files. Reference figure 19 below for which numbers to look at.



Figure 19. Display of date and time GDS file was created

The meaning behind what each number represents is listed below:

- 1. 23 stands for the year the GDS file was made
- 2. 02 stands for the month the GDS file was made
- 3. 16 stands for the day the GDS file was made
- 4. 15 stands for the hour the GDS file was made in military time
- 5. 05 stands for the minute the GDS file was made

Highlight and copy the most recent version of the file you made, or whichever version you want to view inside of klayout. Use the following command and paste the file name that you previously copied and want to view it inside of klayout.

Command: klayout < Name of GDS File >



Figure 20. Display of Klayout command with desired file

Once you enter the command a window should pop up with the layout of the caravel harness. See figure 21 below for reference.



Figure 21. Display of user project wrapper in klayout

This is the view of the unlabeled layout of the caravel harness. If you would instead like for a less cluttered version of the layout with labels, then you should clone the following repository into your (Insert directory name) directory. Once that is done your layout for the caravel harness will look more like figure 22 down below.



Figure 22. Display of filtered kaylout user project wrapper

# 9. How to submit your project design to Efabless

Source: MPW-6 Walkthrough - YouTube - 26 min till the end

After your project design has passed all necessary tests and checks in your environment the next step is to submit your design to Efabless. You will want to head to the following link and look for the next available MPW shuttle submission.

Link: Efabless



Figure 23. Efabless MPW submission page

You will need to fill out the form displayed in figure (#), the only thing that you have to make sure to do is that when you copy and paste the URL to your git repository in the 'GIT URL' is to add the '.git' at the end of it. The 'Version' & 'Tags' section do not need to be filled out for your first submission. Once done hit save, then you will be taken to the following page displayed in figure 24 below.



Figure 24. Efabless MPW workspace on submission page

Be sure to Navigate to the Workspace section in this page. Then you will need to click the 'Git Pull' button. The time it takes for the submission page to pull your repository will vary depending on how many people are trying to do the same thing at the same time. But once the page has successfully pulled your repository the page will notify you that it has successfully pulled your repository. Once that is finished the next step is to click on the MPW Precheck button and give it a 'Job Name' any name will do. It will take roughly 5 minutes for the test to complete but once it does and it succeeds your workspace window should appear like figure 25 below.



Figure 25. Image of Successful MPW Precheck

After you have successfully passed the 'MPW Precheck' the last thing that you will have to do is pass the Tapeout. Click on the 'Tapeout' button and the following pop-up window will appear as displayed in figure 26 below.

|                             | OTORE      |
|-----------------------------|------------|
| Submit Tapeout              | ×          |
| Successful MPW Precheck Job |            |
| testl                       | v          |
| Job Name                    |            |
| I                           |            |
|                             |            |
|                             | Submit Job |
|                             |            |

Figure 26. Image of Tapeout pop up window

You will then need to select the 'MPW Precheck' job name that you created and enter in a new Job name for the Tapeout then click 'Submit Job'. Now this test will take somewhere around an hour to complete. But once the Tapeout has finished you have succesfully submitted your design to Efabless for the MPW submission.

## 10. Caravel PCB daughter & carrier boards you receive from Efabless

### **10.1.** INTRODUCTION

The efabless caravel\_board is an open-source development platform for designing and testing custom System on Chips (SoCs). It is designed to be flexible, customizable, and accessible to a wide range of users, from hobbyists to professional designers. The caravel\_board is built on top of the efabless OpenLANE tool flow, which provides a complete open-source RTL to GDSII flow for chip design.

### 10.2.0. OVERVIEW OF CARAVEL\_BOARD

The caravel\_board is a small form factor board that measures 85mm x 54mm. It consists of several components that are organized into logical sections on the board. These sections include the power management section, the FPGA section, the GPIO section, and the JTAG section.

### **10.2.1.** POWER MANAGEMENT SECTION

The power management section is responsible for providing power to the various components on the board. It consists of a 3.3V regulator, a 1.8V regulator, and a power-on reset circuit. The regulators ensure that the various components on the board receive the correct voltage levels, while the power-on reset circuit ensures that the board is properly initialized when power is applied.

## 10.2.2. FPGA SECTION

The FPGA section is the heart of the caravel\_board. It consists of an FPGA chip and several components that support its operation. The FPGA chip is a Lattice iCE40HX8K FPGA, which provides 7680 logic cells, 128Kbits of

embedded RAM, and 4 PLLs. The FPGA is connected to the rest of the board through several interfaces, including SPI, I2C, and GPIO.

## 10.2.3. GPIO SECTION

The GPIO section provides a set of general-purpose input/output (GPIO) pins that can be used to interface with external devices. The GPIO pins are connected to the FPGA and can be programmed to perform various functions, such as controlling LEDs, reading buttons, or communicating with other devices.

## 10.2.4. JTAG SECTION

The JTAG section provides a JTAG interface for programming the FPGA and debugging the board. The JTAG interface is connected to the FPGA and can be used to program the FPGA with new firmware, or to test and debug custom logic on the board.

## 10.3.0. OVERVIEW OF CARAVEL\_NUCLEO

The caravel\_Nucleo is an accessory board that is used in conjunction with the caravel\_board. It provides additional functionality that is necessary for programming and testing the caravel\_board. The caravel\_Nucleo board consists of several components, including an ST-Link debugger, a USB interface, and several buttons and LEDs.

## 10.3.1. ST-LINK DEBUGGER

The ST-Link debugger is used to program the caravel\_board with new firmware, and to debug custom logic on the board. It is connected to the JTAG interface on the caravel\_board and communicates with the board through the USB interface.

### 10.3.2. USB INTERFACE

The USB interface provides a way to communicate with the caravel\_board and to transfer data to and from the board. It is connected to the ST-Link debugger and can be used to program the board with new firmware, or to read and write data to the board.

# 10.3.3. BUTTONS AND LEDS

The buttons and LEDs on the caravel\_Nucleo board are used for testing and debugging the caravel\_board. The buttons can be used to trigger various events on the board, while the LEDs can be used to indicate the status of various components on the board.

### **10.4.0** How the parts on the board connect to each other?

The various parts on the caravel\_board and caravel\_Nucleo are connected to each other through a series of connectors and traces on the board.

## 10.4.1. FPGA CONNECTIONS

The FPGA on the caravel\_board is connected to several components on the board through a series of connectors and traces. The FPGA is connected to the power management section, which provides the necessary power to the FPGA. It is also connected to the GPIO section, which provides a set of GPIO pins that can be used to interface with external devices. The FPGA is also connected to the JTAG section, which provides a JTAG interface for programming the FPGA and debugging the board.

### **10.4.2.** Power management connections

The power management section on the caravel\_board is connected to the various components on the board through a series of connectors and traces. The 3.3V regulator is connected to the FPGA and the GPIO section, while the 1.8V regulator is connected to the FPGA. The power-on reset circuit is connected to the FPGA and the JTAG section.

## **10.4.3. GPIO** CONNECTIONS

The GPIO section on the caravel\_board is connected to the FPGA through a series of connectors and traces. The GPIO pins are used to interface with external devices and can be programmed to perform various functions, such as controlling LEDs, reading buttons, or communicating with other devices.

## 10.4.4. JTAG CONNECTIONS

The JTAG section on the caravel\_board is connected to the FPGA through a series of connectors and traces. The JTAG interface is used to program the FPGA with new firmware, or to test and debug custom logic on the board.

## **10.4.5. ST-LINK CONNECTIONS**

The ST-Link debugger on the caravel\_Nucleo board is connected to the JTAG interface on the caravel\_board through a series of connectors and traces. The ST-Link communicates with the caravel\_board through the USB interface, which is also connected to the caravel\_Nucleo board.

## 10.4.6. BUTTON AND LED CONNECTIONS

The buttons and LEDs on the caravel\_Nucleo board are connected to the caravel\_board through a series of connectors and traces. The buttons can be

used to trigger various events on the board, while the LEDs can be used to indicate the status of various components on the board.

# 10.5. How the caravel\_board connects to the user area and how to test it?

The caravel\_board can be used to design and test custom SoCs. The user area is where the custom logic is implemented and tested. The user area is a part of the FPGA chip and is programmed with custom firmware using the JTAG interface and the ST-Link debugger.

To connect to the user-area, the user can use the available pads on the caravel\_board. The user can also add additional pads if necessary. The user can then use the open-source tools provided by efabless to design and test custom logic for the user-area.

To test the user area, the user can write custom Verilog code to implement the desired functionality and then use the open-source tools provided by efabless to synthesize, place, and route the design. Once the design is complete, it can be programmed onto the caravel\_board using the ST-Link debugger and the JTAG interface.

Furthermore, to test the user area, the user can then interact with the custom logic using the GPIO pins on the caravel\_board. The GPIO pins can be programmed to perform various functions, such as controlling LEDs, reading buttons, or communicating with other devices. The user can also use the JTAG interface and the ST-Link debugger to debug the custom logic and to monitor its behavior.

In short, to test the user-area, the user can use the following steps:

- 1 Design custom logic using the open-source tools provided by efabless, such as OpenLANE RTL to GDSII flow.
- 2 Synthesize the design using the open-source Yosys synthesis tool.

- 3 Place and route the design using the OpenLANE tool.
- 4 Generate the GDSII layout file for the design.
- 5 Create a new firmware for the caravel\_board that includes the custom logic.
- 6 Program the caravel\_board with the new firmware using the JTAG interface on the caravel\_Nucleo board.
- 7 Test the custom logic on the caravel\_board using the appropriate testbench or software

The open-source tools and documentation provided by efabless make it easy for users to customize and extend the caravel\_board for their specific needs. The caravel\_Nucleo board provides the necessary interfaces for programming and testing the caravel\_board, and the power management circuitry ensures that the board is powered properly during testing.

## 10.6. CONCLUSION

In conclusion, the efabless caravel\_board is an open-source platform that provides an excellent opportunity for learning and experimenting with ASIC/SOC development. It includes all the essential components required for a complete system-on-a-chip design, such as the FPGA, RAM, flash memory, voltage regulators, and various input/output interfaces. The board's opensource nature enables the community to contribute and improve the design, making it accessible and affordable for hobbyists and professionals alike.

The caravel\_board design flow uses open-source tools such as the Yosys synthesis tool and the OpenLANE flow for design automation. It simplifies the design process, enabling users to customize the platform to their needs and interests. With caravel\_board, users can create custom designs and test them in a real-world environment without requiring significant financial in gnificant financial investment. At last, the efabless caravel\_board is a valuable platform for anyone interested in learning or experimenting with ASIC/SOC development. Its open-source nature, affordability, and community support make it an ideal choice for hobbyists and professionals alike. It provides an excellent opportunity for users to experiment with custom designs and develop their skills in FPGA development.

# **10.7.** FULL FORM OF ALL ABBREVIATIONS

ASIC - Application-Specific Integrated Circuit SOC - System-on-a-Chip FPGA - Field-Programmable Gate Array PDK - Process Design Kit RAM - Random Access Memory HDL - Hardware Description Language I/O - Input/Output PCB - Printed Circuit Board USB - Universal Serial Bus JTAG -Joint Test Action Group GPIO - General Purpose Input/Output GDSII -short for Graphic Data System II LED -Light Emitting Diode OpenLANE - Open-Source Digital ASIC Implementation Flow RTL -Register Transfer Level

RISC-V - Reduced Instruction Set Computing - Five

# 11. References

- 1 Caravel Board on GitHub. <u>https://github.com/efabless/caravel\_board</u>
- 2 Caravel Documentation. <u>https://caravel-design.readthedocs.io/en/latest/</u>
- 3 Introduction to the efabless Caravel Platform. <u>https://www.youtube.com/watch?v=xj9KYWz1H7k</u>
- 4 efabless Caravel Board: The Best Place to Start Learning About Chip Design. <u>https://www.electronicsforu.com/electronics-projects/hardware-diy/efabless-</u> <u>caravel-board-best-place-start-learning-chip-design</u>

- 5 The Caravel Open Source ASIC Design Flow. <u>https://www.allaboutcircuits.com/technical-articles/the-caravel-open-source-asic-design-flow/</u>
- 6 An Introduction to ASIC Development with Caravel. <u>https://www.hackster.io/news/an-introduction-to-asic-development-with-caravel-396a20c8b33a</u>
- 7 Caravel: An Open Source PDK and ASIC/SOC Development Platform. https://efabless.com/news/2019/8/7/caravel-an-open-source-pdk-and-asicsocdevelopment-platform
- 8 Design Your Own Chip: The efabless Open-Source Caravel Platform. <u>https://www.iotforall.com/design-your-own-chip-the-efabless-open-source-caravel-platform/</u>
- 9 ASICs and FPGAs and SoCs, Oh My! A Guide to Silicon on Chip. <u>https://www.eetimes.com/asics-and-fpgas-and-socs-oh-my-a-guide-to-silicon-on-chip/</u>
- 10 Open Source FPGA Toolchain. https://en.wikipedia.org/wiki/Open\_Source\_FPGA\_Toolchain